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METHOD AND SYSTEM FOR PROVIDING MULTI -CHANNEL 
FUNCTIONALITY WITH A TELECOMMUNICATION DEVICE 
COMPRISING A SINGLE CHANNEL 



TECHNICAL FIELD OF THE INVENTION 

This invention relates generally to 

telecornmunication devices and more particularly to a 
method and system for providing multi-channel 
functionality with a telecommunication device comprising 
a single channel. 
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BACKGROUND OF THE INVENTION 

Wireless communication systems have been the subject 
of substantial development activity in accordance with 
the ever- increasing demand for better and more flexible 
5 communication devices. Wireless telephone systems are 
also known as portable, cordless or mobile telephone 
systems. A typical wireless communication system has a 
base station that is connected to the Public Switched 
Telephone Network over a wireline interface and 
p 10 communicates with a mobile unit or handset over an air 

interface that permits the user to communicate remotely 

ry 

y from the base station. 

?3 In the past, the enhanced features and high voice 

j,* quality demanded by users have been achieved by the use 

? 15 of sophisticated and complex algorithms and methods that 

require substantial processor resources and large amounts 



of memory. Technical problems associated with the need 
for using faster and more powerful processors include 
larger packaging to accommodate the larger-sized 

20 components. In the past, such wireless systems have been 
large and bulky and have weighed more than what is 
satisfactory to many users. 

While wireless communication devices and methods 
have provided an improvement over prior approaches in 

25 terms of features, voice quality, cost, packaging size 
and weight, the challenges in the field of wireless 
telecommunications have continued to increase with 
demands for more and better techniques having greater 
flexibility and adaptability. 

30 



DALOl: 572867.1 



ATTORNEY DOCKET NUMBER 
TI-29536 



PATENT APPLICATION 



SUMMARY OF THE INVENTION 

In accordance with the present invention, a method 
and system for providing multi-channel functionality with 
a telecommunication device comprising a single channel 
5 are provided that substantially eliminate or reduce 
disadvantages and problems associated with previously 
developed systems and methods. In particular, the 
present invention provides a device memory for storing 
data for each of a plurality of applications such that 
f^, 10 the applications may be executed one after another in a 

y repeating cycle. Thus, each application has exclusive 

ru 

y use of the channel while being executed. 

P In one embodiment of the present invention, a method 

\a for providing multi-channel functionality with a 

f 15 telecommunication device comprising a single channel is 

fy provided. The method includes dividing a scan chain of 



□ 

|i4> 



digital logic components into a plurality of sub-chains. 
A first data set is provided in the sub-chains. The sub- 
chains are linked in parallel. The sub-chains are linked 

20 to a device memory. A first application is executed to 
update the first data set in the sub-chains. The first 
application is operable to use the channel . The updated 
first data set is stored in the device memory. A second 
data set is restored from the device memory to the sub- 

25 chains. A second application is executed to update the 
second data set in the sub-chains. The second 

application is operable to use the channel . 

In another embodiment of the present invention, a 
telecommunication device comprising a single channel is 

30 provided that includes a scan chain, a device memory and 
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a state machine. The scan chain comprises a plurality of 
digital logic components . The device memory is operable 
to store a data set for each of a plurality of 
applications. The state machine is operable to divide 
5 the scan chain into a plurality of sub-chains, to provide 
a first data set in the sub-chains, to link the sub- 
- chains in parallel, to link the sub-chains to the device 
memory, to execute a first application to update the 
first data set in the sub-chains, to shift the updated 
10 first data set into the device memory for storage, to 
Q shift a second data set from the device memory into the 



sub-chains, and to execute a second application to update 
P the second data set in the sub-chains. The first 

I"* application is operable to use the channel, and the 

8 15 second application is operable to use the channel. 



Technical advantages of the present invention 
include providing an improved system for providing multi- 
channel functionality with a telecommunication device 



Q 

comprising a single channel. In a particular embodiment. 



20 a state machine stores data for each of a plurality of 
applications in a device memory. The applications are 
executed one at a time. After each application is 
executed, the data for that application is stored in the 
memory and data for another application is restored from 

25 the memory. As a result, the applications may be 
executed in a repeating cycle with each application 
having exclusive use of the channel during execution. 
Accordingly, multi-channel functionality is provided with 
a single channel. 
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Other technical advantages will be readily apparent 
to one skilled in the art from the following figures, 
description, and claims. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

For a more complete understanding of the present 
invention and its advantages, reference is now made to 
the following description taken in conjunction with the 
accompanying drawings, wherein like numerals represent 
like parts, in which: 

FIGURE 1 is a block diagram illustrating a multi- 
channel device in accordance with one embodiment of the 
present invention; 

FIGURE 2 is a schematic diagram illustrating a flip- 
flop for the multi-channel device of FIGURE 1 in 
accordance with one embodiment of the present invention; 
and 

FIGURE 3 is a flow diagram illustrating a method for 
providing multi-channel functionality with the 
telecommunication device of FIGURE 1 in accordance with 
one embodiment of the present invention. 
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DETAILED DESCRIPTION OF THE INVENTION 

FIGURE 1 is a block diagram illustrating a 
telecommunication device 10 in accordance with one 
embodiment of the present invention. The 
5 telecommunication device 10 may comprise an application- 
specific integrated circuit, a field-programmable gate 
array, or other suitable device capable of providing 
telecommunication functionality. In accordance with' an 
exemplary embodiment, the telecommunication device 10 

H 10 comprises an adaptive differential pulse code modulation, 

P 

P or other suitable waveform codec, implemented in an 

application-specific integrated circuit. 

According to one embodiment, the device 10 may 
comprise a mobile telecommunication unit operable to 



u 

n 15 provide wireless communication with a base or other 

ru 

^ channel. As described in more detail below, however, the 

Q 

channel functionality. The device 10 may comprise part 



mobile telecommunication unit over a single communication 
channel. As described in more detail below, however, the 
single-channel device 10 is operable to provide multi- 



20 of a wireless communication system such as a cellular 
telephone system, local multiple distribution service, or 
other suitable system. For example, according to one 
embodiment, the device 10 is part of a wireless telephone 
operable to communicate with a micro-base station to 

25 provide wireless telephone service for a user. 

The telecommunication device 10 comprises a. hardware 
resource 12, a test module 14, a state machine 16, and a 
device memory 18. The hardware resource 12 comprises a 
plurality of digital logic components 24, in addition to 

30 logic circuitry, which are operable to execute an 
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application that utilizes the single channel for the 
device 10. According to one embodiment, the digital 
logic components 24 comprise flip-flops which are 
operable to pass bits of data through the hardware 
resource 12 while an application is being executed. 

The test module 14 is operable to receive, through a 
test data input terminal 28, input test data 30 for the 
flip-flops 24. The test module 14 is operable to provide 
the input test data 30 to the flip-flops 24 through a 
plurality of scan chains 34. According to one 

embodiment, the flip-flops 24 are linked together in 
eight distinct scan chains 34 such that each of the flip- 
flops 24 in the hardware resource 12 are included in one 
of the eight scan chains 34. It will be understood, 
however, that any suitable number of scan chains 34 may 
be implemented in the hardware resource 12 without 
departing from the scope of the present invention. 

FIGURE 1 illustrates one of the scan chains 34 which 
receives input test data 30a from the test module 14 for 
testing the flip-flops 24 that are linked together in the 
scan chain 34. At the end of the scan chain 34, output 
test data 3 8a is received by the test module 14 and 
provided through a test data output terminal 40a to allow 
the functionality of the flip-flops 24 in the 
corresponding scan chain 34 to be verified. 

For the embodiment in which the flip-flops 24 and 
the hardware resource 12 are linked together in eight 
scan chains 34, input test data 30 received on input 
terminals 28 is provided in a similar manner from the 
test module 14 to each of the scan chains 34. The 
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resulting output test data 38 from each of the scan 
chains 34 is also received by the test module 14 and 
provided through output terminals 40 for verifying the 
functionality of the flip-flops 24. 



invention, each of the scan chains 34 is divided into a 
plurality of sub-chains 42 . The sub-chains 42 for each 
scan chain 34 are linked in parallel with each other and 
are linked to the device memory 18. The number of sub- 

10 chains 42 may comprise the data width, n, for the device 
memory 18, For example, for a device memory 18 with a 
data width of 16, each scan chain 34 may be divided into 
16 sub-chains 42. However, it will be understood that 
each scan chain 34 may be divided into any suitable 

15 number of sub-chains 42 without departing from the scope 
of the present invention. 

According to one embodiment, the device memory 18 
comprises a dual port memory with a write port 44 and a 
read port 46. Thus, the device memory 18 may receive 

20 data from each of the sub-chains 42 through the write 
port 44, while providing data to each of the sub-chains 
42 through the read port 46. Each scan chain 34 may have 
its own device memory 18 for storing data from the 
corresponding sub-chains 42. Alternatively, a device 

25 memory 18 may store data for the sub-chains 42 of two or 
more scan chains 34. However, in this embodiment, the 
data width for the device memory 18 is divided among each 
of the scan chains 34 sharing the device memory 18, 
decreasing the number of sub-chains 42 possible for each 

30 scan chain 34 accordingly. 



5 



In accordance with one embodiment of the present 
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The state machine 16 is operable to divide each scan 
chain 34 into a plurality of sub-chains 42. The state 
machine 16 is also operable to link the sub-chains 42 
from each scan chain 34 in parallel with each other and 
5 to link the sub-chains 42 to the device memory 18. The 
state machine 16 is also operable to shift data from each 
of the sub-chains 42 into the device memory 18 through 
the write port and to shift data from the device memory 
18 into each of the sub-chains 42 through the read port 
P 10 46. The state machine 16 is also operable to execute a 

0 plurality of applications for the device 10, each of 

ru 

y which is operable to utilize the hardware resource 12. 

P In operation, the state machine 16 may place the 

|,A device 10 in a test mode for testing flip-flops 24, a 

^ 15 functional mode for executing applications, and a switch 

ru mode for switching between applications- While the 

'^^ device 10 is in the test mode, the flip-flops 24 in the 

P hardware resource 12 are linked together in scan chains 

34. The flip-flops 24 in each scan chain 34 process 
20 input test data 3 0 using a test clock signal from the 
test module 14. The test data is passed through each of 
the flip-flops 24 in the scan chain 34, and output test 
data 3 8 at the end of the scan chain 34 is provided to 
the test module 14. The output test data 38 may then be 
25 analyzed in order to verify that the flip-flops 24 in the 
corresponding scan chain 34 are functioning properly. 

While the device 10 is in the functional mode, the 
state machine 16 may execute one of a plurality of 
applications. In this mode, the flip-flops 24 and other 
30 logic circuitry in the hardware resource 12 are linked 
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together in accordance with the application being 
executed by the state machine 16. The flip-flops 24 
process functional data using a functional clock signal 
while the application is being executed. 
5 While the device 10 is in the switch mode, the state 

machine 16 divides each scan chain 34 into sub-chains 42. 
The state machine 16 also links the sub-chains 42 for 
each scan chain 34 in parallel with each other and links 
the sub-chains 42 to the ports 44 and 46 of the device 
10 memory 18. The flip-flops 24 receive functional data 



from the device memory 18 through the read port 46 for an 
application to be subsequently executed when the device 



ru 
w 

□ 10 is next placed into the functional mode. The flip- 

s 15 memory 18 through the write port 44 for the application 



flops 24 also provide functional data to the device 
memory 18 through the write port 44 for the application 
previously executed when the device 10 was most recently 
in the functional mode. In addition, the flip-flops 24 
use the functional clock signal while the device 10 is in 



^4 in the functional mode. In addition, the flip-flops 24 

P 

f»4= the switch mode 



20 Thus, the state machine 16 may place the device 10 

in the functional mode to execute a first application for 
the device 10 using the channel, place the device 10 in 
the switch mode to switch to a second application, and 
then place the device 10 in the functional mode to 

25 execute the second application for the device 10 using 
the channel. While in the switch mode, the state machine 
16 shifts the data for the first application from the 
flip-flops 24 into the device memory 18 for storage. The 
state machine 16 simultaneously shifts the data for the 

30 second application into the flip-flops 24 from the device 
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memory 18. Thus, when the device 10 is placed back in 
the functional mode, the state machine 16 may execute the 
second application with the appropriate data in the flip- 
flops 24. In this way, the state machine 16 may cycle 
through each of a plurality of applications, thereby 
allowing each application to make use of the channel. 

FIGURE 2 is a schematic diagram illustrating a flip- 
flop 24 for the telecommunication device 10 in accordance 
with one embodiment of the present invention. The flip- 
flop 24 receives functional data through a functional 
data line 50 and receives test data through a test data 
line 52. The flip-flop 24 receives a switch signal on a 
switch line 54 and a test signal on a test line 56. The 
flip-flop 24 receives a functional clock signal on a 
functional clock line 58 and a test clock signal on a 
test clock line 60. The flip-flop 24 generates an output 
at an output line 62 . 

The flip-flop 24 comprises a multiplexer 64 for 
selecting between the functional data on line 50 and the 
test data on line 52. A multiplexer 66 provides a 
selection between the functional clock signal on line 58 
and the test clock signal on line 60. An OR gate 68 
couples the switch line 54 and the test line 56 to the 
multiplexer 64 in order to select the appropriate input 
data from line 50 or 52. The test signal on the test 
line 56 is also provided to the multiplexer 66 for 
selecting the appropriate clock signal from line 58 or 



In operation, when the device 10 is in the 
functional mode, the switch signal and the test signal 



60. 
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are both low on lines 54 and 56. As a result, a low 
signal is passed from the OR gate 68 to the multiplexer 
64. Based on this low signal, the multiplexer 64 selects 
the functional data on line 50 for processing by the 
flip-flop 24. The low signal on the test line 56 is also 
provided to the multiplexer 66, resulting in the 
functional clock signal on line 58 being selected for the 
flip-flop 24. Thus, while in the functional mode, the 
flip-flop 24 processes functional data on line 50 using 
the functional clock signal on line 58. 

While in the test mode, the test signal on the test 
line 56 is high. As a result, a high signal is passed 
from the OR gate 68 to the multiplexer 64. Based on this 
high signal, the multiplexer 64 selects the test data on 
line 52 for processing by the flip-flop 24. The high 
signal on the test line 56 is also provided to the 
multiplexer 66, resulting in the test clock signal on 
line 60 being selected for the flip-flop 24. Thus, while 
in the test mode, the flip-flop 24 processes test data on 
line 52 using the test clock signal on line 60. 

While in the switch mode, the switch signal on the 
switch line 54 is high. As a result, a high signal is 
passed from the OR gate 68 to the multiplexer 64. Based 
on this high signal, the multiplexer 64 selects the data 
on line 52 for processing by the flip-flop 24. However, 
the test signal on the test line 56, which is low, is 
provided to the multiplexer 66, resulting in the 
selection of the functional clock signal on line 58. 
Thus, while in the switch mode, the flip-flop 24 
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processes data on line 52 using the functional clock 
signal on line 58. 

It will be understood that the low and/or high state 
of any of the signals utilized in the flip-flop 24 may be 
5 reversed to achieve the same results without departing 
from the scope of the present invention. Thus, any 
signal state for the signals may be used which results in 
functional data on line 50 and the ^functional clock 
signal on line 58 being processed during the functional 
10 mode, test data on line 52 and the test clock signal on 
P line 60 being processed during the test mode, and 



ru 



functional data on line 52 and the functional clock 
signal on line 58 being processed during the switch mode. 
FIGURE 3 is a flow diagram illustrating a method for 
« 15 providing multi-channel functionality with the 

Iz telecommunication device 10 in accordance with one 

f»4 embodiment of the present invention. The method begins 

at decisional step 100 where the state machine 16 
i?A determines whether to place the device 10 in the test 



20 mode or the functional mode. If the device 10 is to be 
placed in the test mode, the method follows the Test 
branch from decisional step 100 to step 102. 

At step 102, the state machine 16 links the flip- 
flops 24 of the hardware resource 12 together in serial 

25 scan chains 34, as described above in connection with 
FIGURE 1. At step 104, the state machine 16 links the 
scan chains 34 to the test module 14. At step 106, test 
operations are performed on the flip-flops 24 in order to 
verify the functionality of the flip-flops 24. 
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Returning to decisional step 100, if the state 
machine 16 determines that the device 10 is to be placed 
in the functional mode, the method follows the Functional 
branch from decisional step 100 to decisional step 108. 
5 At decisional step 108, the state machine 16 determines 
whether the device 10 is to provide multi -channel 
functionality. If the device 10 is not to provide 
multi-channel functionality, the method follows the No 
branch from decisional step 108 to step 110. At step 
10 110, the state machine 16 executes the application for 



fU 



the device 10 . 

Returning to decisional step 108, if the device 10 
is to provide multi-channel functionality, the method 
j,4 follows the Yes branch from decisional step 108 to step 

I 15 112. At step 112, the state machine 16 separates each 

fIJ scan chain 34 from the test module 14. At step 114, the 

1,4, 

state machine 16 divides each scan chain 34 into a 
P plurality of sub-chains 42 based on the data width for 



the device memory 18. At step 116, the state machine 16 
20 links the sub-chains 42 to the device memory 18. 

At step 118, an application identifier, I, is set to 
one. At step 120, the state machine 16 executes 
Application I. At step 122, the state machine 16 places 
the device 10 in the switch mode. At step 124, the state 
25 machine 16 stores data for Application I in the device 
memory 18, while restoring data for Application I+l from 
the device memory 18. At step 126, the state machine 16 
places the device. 10 in the functional mode. 

At step 128, the application indicator is 
30 incremented by one. At decisional step 130, the state 
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machine 16 determines whether I+l exceeds the number of 
applications that are to be executed for the device 10 . 
If I+l does not exceed the number of applications, the 
method follows the No branch from decisional step 130 and 
returns to step 120 where the state machine 16 executes 
Application I, which is the application following the 
previously executed application. 

Returning to decisional step 130, if I+l exceeds the 
number of applications, Application I is the final 
application to be executed before cycling back to the 
first application. In this situation, the method follows 
the Yes branch from decisional step 130 to step 132 where 
the state machine 16 executes Application I. At step 
134, the state machine 16 places the device 10 in the 
switch mode. 

At step 136, the state machine 16 stores data for 
Application I in the memory, while restoring data for the 
first application from the device memory 18. At step 
138, the state machine 16 places the device 10 in the 
functional mode before returning to step 118, where the 
application indicator, I, is reset to one. 

Because the data in the flip-flops 24 for each 
application is stored in the device memory 18, the 
hardware resource 12 may be returned to the same state in 
which the application existed at the conclusion of the 
previous execution of the application in order to 
continue execution of the application. In this way, the 
state machine 16 is able to execute a plurality of 
applications by cycling through each application and 
allowing each application exclusive use of the hardware 
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resource 12 and the channel while the application is 
identified by the application indicator. 

Although the present invention has been described 
with several embodiments, various changes and 
modifications may be suggested to one skilled in the art. 
It is intended that the present invention encompass such 
changes and modifications as fall within the scope of the 
appended claims. 
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